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FIELD OF THE INVENTION 

The present invention relates to an image 
processing apparatus and method and, more particularly, 
to an image processing apparatus and method for 
extracting a region of interest in a moving image or a 
multi-viewpoint image . 

BACKGROUND OF THE INVENTION 

Typical -techniques for automatically extracting a 
specific region of interest from a set of a plurality 
of images include (1) a scheme exploiting a motion 
vector, and (2) a scheme based on an active contour 
model. Examples of schemes (1) and .(2) will be 
explained below. 
[Scheme using motion vector] 

•Patent No. 2500439 (Predictive coding scheme for 
moving image) 

In motion-compensated inter-frame predictive 
coding of a moving image, it is a common practice to 
break up an input image into blocks each having a 
predetermined size, and to make motion-compensated 
inter-frame prediction in units of blocks. By contrast, 
in this patent, when a given block has a prediction 
error larger than a predetermined threshold value, it 
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is determined that the block is highly likely to 
include a boundary of objects that make different 
motions, and the parent comprises means for segmenting 
that block into sub-blocks, and making 
5 motion-compensated inter-frame predictive coding in 
units of sub-blocks. That is, by increasing the 
resolution of the boundary between objects which make 
Ej different motions, coding efficiency is improved. 

m ©Patent No. 2616552 (Moving image encoding/decoding 

jjl 10 apparatus) 

This encoding/decoding apparatus performs 
motion-compensated inter-frame prediction using motion 
vectors obtained in units of pixels of an input image. 
This apparatus has means for detecting contour line 
15 data of an object region from an input image, and 

accurately reproduces an abrupt change in motion vector 
near a contour line by inhibiting motion vectors of 
different objects from being used in interpolations 
upon computing motion vectors in units of pixels by 
20 interpolations, thereby improving coding efficiency. 
•Japanese Patent Laid-Open No. 8-335268 (Region 
extraction method) 

Block matching between the previous and current 
frames is made under the assumption that the contour of 
25 a region of interest is given in the previous frame of 
an input moving image, thereby estimating the motion 
vector of a feature point on the contour. Then, the 
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candidate position of the contour in the current frame 
is determined based on the estimation result of the 
motion vector. The gradient vector field of the 
current frame is computed in that contour candidate 
5 region. Finally, a third-order or cubic spline curve 
that passes through points corresponding to large 
vectors in the gradient vector field is generated, thus 
extracting a region of interest. 
'!f [Scheme based on active contour model] 

10 With active contour models called Snakes 

described in M. Kass, A. Witkin, D. Terzopoulos, 
"Snakes: Active Contour Models", International Journal 
C;j of Computer Vision, Vol. 1, No. 4, p. 321-331, 1988, 

the contour line of a region of interest is extracted 
Ij 15 by shrinking and deforming the contour to minimize the 
sum total of energy (internal energy) applied in 
correspondence with the contour shape, energy (image 
energy) applied in accordance with the nature of image, 
and energy (external energy) applied externally. The 
20 internal energy is defined to assume a smaller value as 
the shape of the contour line is smoother, the image 
energy is defined to assume a smaller value as the edge 
strength of an image on the contour line is higher, and 
the external energy is defined to assume a smaller 
25 value as the contour line is closer to an externally 
given point. 
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The aforementioned prior arts respectively suffer 
the following problems. 

(1) Patent No. 2500439: The contour line resolution is 
low 

5 Even when the resolution is increased by 

decreasing the block size near the contour, it is 
merely a resolution in units of blocks, and contour 
data in units of pixels cannot be accurately obtained. 
Additional information for discriminating if a block 
10 has been broken up again is generated for each block, 
thus lowering the compression ratio. 

(2) Patent No. 2616552: Contour detection precision is 
low 

Four different contour detection methods have 
15 been explained, but respectively have the following 
problems . 

A method of extracting a contour from difference 
data between the previous and current frames can 
extract a region with a large difference, but requires 

20 some post-processes such as thin line conversion and 
the like so as to extract a contour line from the 
region with the large difference. 

A method of extracting a contour from difference 
data between contour data of the previous and current 

25 frames can extract a region with a large difference, 
but requires some post-processes such as thin line 
conversion and the like so as to extract a contour line 
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from the region with the large difference, as in the 
above method. 

A method of extracting a contour from the 
difference from a registered background image has poor 
5 versatility since the background is fixed. 

A method of detecting motion vectors in advance, 
and extracting a contour from a position where the 
motion vector distribution changes abruptly can only 
obtain a contour line at a resolution as low as that in 
10 units of blocks from which motion vectors are detected. 

(3) Japanese Patent Laid-Open No. 8-335268: Resolution 
in units of pixels cannot be obtained 

Since portions of contour data are expressed by a 
'^'^ spline function, the contour of an object cannot be 

CIj 15 extracted with precision as high as that in units of 

r'- 

pixels . 

(4) Scheme based on active contour model 

First, the versatility is poor. Parameters for 
determining the behavior of a contour model, i.e., the 

20 weighting coefficients of respective terms of the 

internal energy, image energy, and external energy must 
be empirically set for each input image, resulting in 
poor versatility. 

Second, the result is too sensitive to initial 

25 setups of a contour. An accurate initial position must 
be given, and a low initial setup precision of the 
contour readily yields a minimal value of the energy 
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distribution and cannot be easily converged to a 
correct contour. 

Third, the computation volume is large, and it is 
hard to attain high-speed processes. In order to 
5 determine the moving direction of one node on a contour, 
the aforementioned energy values are obtained for 
neighboring points in all possible movable directions 
of that node, and such arithmetic operations must be 
made on all nodes on the contour, thus disturbing 

10 high-speed processes. 

Fourth, this method is readily influenced by a 
false edge and noise near the contour. Since the image 
energy is defined to select a pixel having a high edge 
strength, if the strength of a false edge or noise near 

15 the contour line is higher than the edge strength of a 
true contour line, the false edge or noise is 
erroneously selected. 

SUMMARY OF THE INVENTION 
20 The present invention has been made to solve the 

aforementioned problems individually or together, and 
has as its object to extract a region of interest, 
which extends across a plurality of images such as a 
moving image, multi-viewpoint image, and the like, at 
25 high speed and high precision. 

In order to achieve the above object, a preferred 
embodiment of the present invention discloses an image 
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processing apparatus comprising: a selector, arranged 
to select a plurality of feature points on or near a 
contour line of a region of interest when a contour of 
the region of interest in a reference image sensed at 
5 reference time or viewpoint is input; a memory for 
storing a connectivity between the plurality of 
selected feature points; a seeker, arranged for seeking 
a plurality of corresponding points, which respectively 
correspond to the plurality of feature points, in an 
10 image to be sought, which is sensed at another time or 
viewpoint; and an extractor, arranged to extract a 
contour between the plurality of corresponding points 
as a region of interest of the image to be sought on 
the basis of the connectivity stored in said memory. 

15 

Other features and advantages of the present 
invention will be apparent from the following 
description taken in conjunction with the accompanying 
drawings, in which like reference characters designate 
20 the same or similar parts throughout the figures 
thereof . 



BRIEF DESCRIPTION OF THE DRAWINGS 
Fig. 1 is a block diagram showing an example of 
25 the functional arrangement of the first embodiment; 
Fig. 2 is a flow chart for explaining a 
representative point select method; 
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Fig. 3 is a view for explaining the principle of 
Freeman chain-code representation that expresses a line 
in a digital images- 
Fig. 4 is a view for explaining the principle of 
Freeman chain-code representation that expresses a line 
in a digital image; 

Fig. 5 is a view showing a state wherein the 
resolution of the digital image shown in Fig. 3 is 
reduced to 1/2 in both the horizontal and vertical 



^'^ 10 directions; 



fiJ Fig. 6 is a view showing nine feature points 

selected from the closed curve shown in Fig. 5; 
£;j Figs. 7A and 7B are views for explaining a 

l^.i: labeling update method shown in Fig. 2; 

r;j 15 Figs. 8A to 8C are views for explaining the 

labeling update method shown in Fig. 2; 

Fig. 9 is a block diagram showing an example of 
the internal arrangement of a contour extractor; 

Fig. 10 is a flow chart that best illustrates the 
20 internal process of an edge trace section shown in 
Fig. 9; 

Fig. 11 is a view showing categories of angles 
the point of interest and the target point make with 
each other; 

25 Fig. 12 shows examples of screen masks; 

Fig. 13 shows movable ranges of contour trace; 
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Fig. 14 shows a contour line and a point of 
interest which is tracing the period of the contour 
line; 

Fig. 15 is a block diagram showing an example of 
5 the detailed arrangement of a contour extractor 
according to the second embodiment; 

Fig. 16 shows other examples of screen masks; 
Fig. 17 shows contour traceable ranges when the 
H screen masks shown in Fig. 16 are used; 

10 Figs. 18A to 18D show examples of screen masks 

using multi-valued weighting coefficients; 

Fig. 19 is a view for explaining a two-way trace 
effect; 

Fig. 20 is a view for explaining a two-way trace 
15 effect; and 

Fig. 21 is a flow chart showing the process of 
the fourth embodiment. 

DESCRIPTION OF THE PREFERRED EMBODIMENTS 
20 An image processing apparatus according to an 

embodiment of the present invention will be described 
in detail hereinafter with reference to the 
accompanying drawings . 

Note that image data of a region of interest 
25 extracted by contour extraction to be described below 
is converted into data in the frequency domain, and 
then undergoes image processes such as quantization 

- 9 - 



using a quantization method or table different from 
another region, variable-length coding, and the like. 
First Embodiment 
[Arrangement ] 

Fig. 1 is a block diagram showing an example of 
the functional arrangement of the first embodiment. 

Referring to Fig. 1, reference numeral 10 denotes 
a contour extractor for extracting the contour of a 
region of interest in an input image; 20, a feature 
point selector for selecting a plurality of feature 
points present on or near the extracted contour; 25, a 
feature point connectivity memory for storing 
connectivities among the selected feature points; 30, a 
corresponding point seeker for searching an image 
obtained by sensing an object at another time or from 
another viewpoint for points corresponding to the 
plurality of feature points; 40, an image memory for 
storing an input image; and 50, a delay circuit for 
holding the addresses of a plurality of newly obtained 
feature points for a predetermined period of time. 

Note that the present invention can be 
implemented by not only the apparatus with the 
arrangement shown in Fig. 1 but also by executing a 
program code having the following steps on a versatile 
personal computer or workstation: a program code which 
comprises at least the edge extraction step of 
extracting a contour of a region of interest of an 




image, the feature point select step of selecting 
feature points on the extracted contour line, the step 
of storing connectivities among the feature points in a 
memory, the corresponding point seek step of searching 
5 another image for points corresponding to the feature 
points, and the step of supplying the corresponding 
points to the contour extraction step, and which 
sequentially extracts regions of interest which extend 
across a plurality of images. 

10 . The functional blocks shown in Fig. 1 will be 

explained below in the order they operate. 

Initial contour information of a region of 
interest in a reference image is input to the contour 
extractor 10. When time-series images such as moving 

15 images, continuous shot images, and the like are input, 
the operator may designate key points on the contour 
line of the region of interest in the initial image, or 
difference data between two, time-series images may be 
used. Note that a method of acquiring initial contour 

20 information of the region of interest is not 

particularly limited, and various other methods may be 
used without departing from the gist of the present 
invention . 

A contour extraction method between feature 
25 points upon giving key points on the contour line as 
feature points or control points will be explained 
later. In this embodiment, time-series images will be 
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exemplified as input images, but multi-viewpoint images 
may be used instead. 

The feature point selector 20 selects points that 
represent features of the contour line well on or near 
the contour line. Fig. 2 is a flow chart for 
explaining a representative point select method. 

When address data of a closed curve that 
represents a contour line are input, the shape of the 
closed curve is analyzed in step SI in Fig. 2. As a 
method of expressing lines such as straight lines, 
curves, closed curves, and the like in a digital image. 
Freeman chain-code representation is known. The 
principle of Freeman chain-code representation will be 
described below with reference to Figs. 3 and 4. 
Fig. 3 shows a heart-shaped closed curve on a digital 
image, and the interior of that closed curve 
corresponds to the region of interest of the image. 
Fig. 4 shows quantization codes in eight directions, 
which are used to digitize the positional relationships 
between neighboring pixels on the contour lines. When 
the closed curve in Fig. 3 is described clockwise to 
have point A as a start point, it is digitized to be 
00066000201006 

In step S2, points where the direction of the 
contour line changes abruptly are selected based on 
Freeman chain codes. For example, points where the 
codes change from 0 to 6, 6 to 0, 0 to 2, 2 to 0, and 
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so forth indicate that the path of the contour line is 
bent through 90°, and corners of the contour line can 
be easily detected. However, many points where the 
contour line path is bent through 90° can be present on 
5 the contour line. For example, an oblique 45° straight 
line repeats 90° inflections at a short period like 
64646464.... For this reason, no feature point is 
selected from inflections which repeat at a 

: s 
■stc 

%i predetermined period or less. 

UJ 10 In order to maintain an appropriate number of 

£11 

flJ feature points, it is effective to, e.g., decimate a 

fc.i Freeman chain code or to reduce the resolution of the 

tj image itself, in addition to the aforementioned process. 

Fig. 5 shows a state wherein the resolution of the 
15 digital image shown in Fig. 3 is reduced to 1/2 in both 
the horizontal and vertical directions. Freeman chain 
codes are generated clockwise to have point A' shown in 
Fig. 5 as a start point in units of coarse pixels each 
defined by four pixels of an original image so as to 
20 extract large inflection points on the path of the 
contour line. Since the resolution lowers, feature 
points remain en grand, and unnecessarily fine points 
of inflection are removed. 

Acute corners which make an angle of inflection 
25 less than 90°, and obtuse corners which make an angle 
of 135° or larger are selected as feature points 
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without any omissions. Also, at least three feature 
points are selected to generate a closed curve. 

The feature point connectivity memory 25 stores 
connectivities among the feature points selected by the 
5 feature point selector 20. Fig. 6 shows nine feature 
points selected from the closed curve shown in Fig. 5, 
and feature points are indicated by hatching. The 
feature points are labeled clockwise from No. 1 to 
No. 9 to have point A' as a start point in the order 
10 the Freeman chain codes are generated. Feature points 
having serial labeling numbers or the first (No. 1) and 
last (No. 9) feature points form a pair used in contour 
trace. The labeling numbers assigned to the feature 
points are taken over when the corresponding point 
I'J 15 seeker 30 searches the next frame for corresponding 

s . 

points of the feature points of the current frame. 

The labeling update method in step S3 shown in 
Fig. 2 will be described below using Figs. 7A to 8C in 
association with the contour extractor 10, 

20 corresponding point seeker 30, and the like, which are 
connected before and after the memory 25. 

Fig. 7A shows the contour line of a region of 
interest at given time. Three feature points A, B, and 
C are selected, as shown in Fig. 7A. The data of this 

25 contour line are stored in a linear sequence to have a 
given feature point as a head point, as shown in 
Fig. 8A. The selected feature points A, B, and C are 

- 14 - 



s 

S IS, 

s ss 



labeled No. 1, No. 2, and No. 3 in the order they 
appear. 

Fig. 7B shows the contour line of the region of 
interest after an elapse of a predetermined period of 
time, i.e., a state wherein the shape has changed. 
Corresponding points A', B', and C of the feature 
points A, B, and C are obtained by the corresponding 
point seeker 30 (to be described later) . The contour 
extractor 10 extracts the contour line of the region of 



I'J 10 interest after an elapse of a predetermined period of 

riJ time using these corresponding points A', B', and C as 

111 

|=.i passing points. Contour line data immediately after 

contour extraction are stored in a linear sequence 
having the head feature point A the predetermined 
15 period of time before, as shown in Fig, 8B. The 

feature point selector 20 selects new feature points D, 
E, and F from the contour data shown in Fig. 8B. 
Fig. 8C shows contour data by shifting the addresses so 
that the feature point D is located at a head position. 
20 The new feature points D, E, and F are newly labeled 
No. 1, No. 2, and No. 3 in the order they appear, and 
are stored in the feature point connectivity memory 25. 
Also, the new feature points D, E, and F become new 
reference pixels which are used to search for the next 
25 corresponding points by the corresponding point seeker 
30. 
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As described above, in step S3 in Fig. 2, feature 
point update, delete, and addition processes (to update 
labeling) are automatically executed in accordance with 
a change in shape of an object. 
5 The corresponding point seeker 30 searches the 

next frame for points corresponding to the plurality of 
feature points extracted by the feature point extractor 
20. Correspondence of feature points can be determined 
at high speed by block matching using blocks each 
10 consisting of each feature point and its neighboring 
pixels. However, that correspondence method is not 
limited to block matching, but any other methods may be 
used if they fall within the scope of the present 
invention . 

15 The image memory 40 is a storage device such as a 

frame memory for temporarily storing image data, and 
contour extraction of the contour extractor 10 is done 
while reading out image data stored in the image memory 
40. The delay circuit 50 temporarily stores address 

20 data of feature points in the latest image, which are 

extracted by the corresponding point seeker 30 so as to 
synchronize them with image data read by the contour 
extractor 10 from the image memory 40. 
[Contour Extractor] 

25 The internal process of the contour extractor 10 

will be described in detail below. Fig. 9 is a block 
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diagram showing an example of the internal arrangement 
of the contour extractor 10. 

An edge extraction section 90 extracts edge 
components from an image supplied from the image memory 
40. An edge trace section 100 traces pixels with large 
edge strength in turn to have one of two connected 
feature points as a start point and the other as an end 
point. In this edge trace process. Freeman chain codes 
are automatically generated, and are supplied to the 
feature point selector 20 together with the edge trace 
result . 

An edge extraction method in the edge extraction 
section 90 may be implemented by either a space 
differential process represented by Sobel operators, 
Laplacian operators, and the like, or template matching 
using Prewitt operators, Kirsch operators, and the like. 
That is, the scheme to be adopted is not particularly 
limited as long as edge extraction can be achieved. 
Note that the edge extraction process may be limited to 
a contour extraction period, and a contour traceable 
range determined by a screen mask (to be described 
later) so as to reduce the arithmetic operation volume 
of edge extraction. Furthermore, the edge extraction 
section 90 may be built in the edge trace section 100, 
and at the instance when the addresses of neighboring 
pixels, whose edge strengths are to be compared, are 
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determined^ only those neighboring pixels may undergo 
edge extraction. 

Fig. 10 is a flow chart which best illustrates 
the internal process of the edge trace section 100. 

A contour period to be extracted is set (SllO) , 
and its two end points (start and end points) are set 
to have the start point of the set contour period as an 
initial position of the point of interest, and the end 
point as the target point of contour trace (S120) . The 
positional relationship between the point of interest 
and target point is computed (S130) , a screen mask that 
limits the field of view of neighboring pixels of the 
pixel of interest is generated (S140) , neighboring 
pixels of the pixel of interest are searched for a 
pixel having a maximum edge strength (S150) , and the 
found contour pixel is set as a new point of interest 
(S160) . It is checked in step S170 if the new point of 
interest matches the target point. 

Contour line data are formed by recording 
addresses (coordinate values) of points of interest, 
and Freeman chain codes are generated by sequentially 
recording the moving directions of the points of 
interest . 

The processes of the individual steps shown in 
Fig. 10 will be described in detail below. 

The operator can set the contour extraction 
period in step SllO by designating two end points that 



sandwich a contour period to be extracted, using a 
pointing device such as a mouse or the like on an 
initial screen of contour trace. More specifically, 
the operator moves the mouse cursor on the screen to 
place it near the end point of the contour period to be 
extracted/ and presses a mouse button. After the 
initial screen, the contour extraction period is set by 
a pair of connected feature points which are supplied 
from the corresponding point seeker 30. 

In step S120 of the initial screen, at the 
instance when the mouse button is pressed, pixels 
within a given distance range having the position 
pointed by the mouse cursor as the center are searched 
for a pixel having the highest edge strength. Likewise, 
in step S120 after the initial screen, connected pixels 
within a given distance range having a feature point 
which is supplied from the corresponding point seeker 
30 are searched for a pixel having the highest edge 
strength. The position of the found pixel is 
determined to be an end point, a point designated first 
is set as the start point, and a point designated next 
is set as the end point. Note that the start point is 
the initial position of the point of interest, and the 
end point is the target point in contour trace. 

In step S130, the positional relationship between 
the point of interest and target point is computed. 
More specifically, the angle the point of interest 



makes with the target point is computed with reference 
to the target point. Let (xO, yO) be the coordinate 
position of the point of interest, and (xl, yl) be that 
of the target point. Then, an angle 9 the two points 
make with each other is given by: 

e = tan'M (yO - yl) / (xO - xl) } ... (1) 

The angle G given by equation (1) is categorized into 
one of eight directions in 45° increments, i.e., 
direction 1 (from -22.5"* to +22.5°), direction 2 (from 
22.5° to 67.5°), direction 3 (from 67.5° to 112.5°), 
direction 4 (from 112.5° to 157.5°), direction 5 (from 
157.5° to 180° and from -180° -157.5°), direction 6 

(from -157.5° to -112.5°), direction 7 (from -112.5° to 
-67.5°), and direction 8 (from -67.5° to -22.5°), as 
shown in Fig. 11. Note that the arithmetic operation 
described by equation (1) can be implemented at high 
speed using a look-up table. 

In step S140, neighboring eight pixels having as 
the center the point of interest on the contour line 
which is being traced are masked by screen masks 

(Fig. 12) corresponding to the eight directions. In 
Fig. 12, the position of the point of interest is 
indicated by a mark x, "1" indicates a movable pixel, 
and "0" indicates a movement-inhibited pixel, i.e., 
masked pixel. This screen mask includes five movable 
pixels and three movement-inhibited pixels, and imposes 
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restrictions to assure convergence on the target point 
while allowing relatively free contour trace. 

In step S150, neighboring pixels which are not 
masked in step S140 are searched for a pixel having the 
5 highest edge strength. In step S160, a pixel position 
moves by one pixel to the next point of interest as the 
pixel found in step S150. 
f^j Fig. 13 shows movable ranges of contour trace 

fi^ according to this embodiment. 

I .2 

10 A contour traceable range allows free trace 



L.E, 



except for a direction to recede from target point B. 
At the instance when point C of interest is located at 
start point A, i.e., at the beginning of contour trace, 
the point of interest can move within a maximum of the 

15 range of octagon a. However, point C of interest does 
not always freely move within the range of octagon a 
before it reaches end point (target point) B, and the 
movable region is limited to the range of octagon b 
after it reaches the contour of, e.g., octagon b. In 

20 this way, the octagon as the movable range gradually 
reduces as the point of interest becomes closer to 
target point B, thus reliably guiding the point of 
interest to target point B. 

It is checked in step S170 if point C of interest 

25 has reached end point B. If end point B has not been 
reached yet, the flow returns to step S130 to repeat 
processes in steps S130 to S160 for new point C of 
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interest. If it is determined in step S170 that point 
C of interest has reached end point B, the contour 
extraction process ends. 

In this embodiment, a mask that prevents the 
point of interest from receding is provided in addition 
to the screen masks. 

Fig. 14 shows contour line A - B, and point C of 
interest which is tracing that period. When point C of 
interest has reached a position illustrated in Fig. 14, 



10 since the positional relationship with end point B as a 



target point belongs to direction 5 (from 157.5° to 
180° and from -180° to -157.5°), the screen mask of 
direction 5 allows movements in directions b and h (up 
and down) , direction f (right) , direction c (upper 
tj 15 right), and direction i (lower left). In the example 
in Fig. 14, since edges are present at pixel b above 
point C of interest, and pixel h below point C, the 
moving path is limited to two, i.e., up and down 
directions. At this time, if the edge strength of 
20 pixel h is higher than that of pixel b, contour trace 
can no longer move forward based on only a rule "to 
trace pixels having higher edge strengths in turn" and 
the screen masks. 

To solve this problem, in this embodiment, in 
25 addition to the screen masks that limit the moving 

directions of contour trace, a field limitation that 
prevents point C of interest from receding is 
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auxiliarily imposed to prevent contour trace from 
returning to the previous contour trace path, i.e., 
from moving backward. That is, at the instance when 
point C of interest has reached the position 
5 illustrated in Fig. 14, since point C of interest has 
moved from pixel h to pixel e, a field limitation is 
imposed to prevent point C of interest from moving to 
pixels g, h, and i backward with respect to the moving 

r ■ 5 

--3 direction. 

m 

10 In the above description, neighboring pixels are 

fij eight pixels that neighbor point C of interest. 

M However, if no detailed contour trace is required or a 

rj smoother contour is to be extracted, the same process 

:s: 

^,1, may be done using neighboring pixels which are 

uJ 

fi- 15 separated two or more pixels from point C of interest. 

As described above, according to the first 
embodiment, the following effects can be obtained. 

(1) Since the contour extraction process is 
implemented by comparing local edge strengths, and 

20 corresponding point seek of feature points is made by 
searching local similar points, high processing speed 
is assured, and a common region of interest can be 
quickly extracted from a plurality of images. 

(2) Since the screen mask that limits the field 
25 of view is appropriately set in the contour extraction 

process every time the point of interest moves, the end 
point (target point) can be reliably reached while 
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assuring a contour trace path with a high degree of 
freedom, thus guaranteeing high reliability. 

(3) Since the constraint condition of contour 
trace in the contour extraction process is only "not to 
recede from the target point", the trace path has a 
very high degree of freedom, and an indirect contour 
that reaches the target point from behind in a contour 
line having a slow change in curvature can be traced. 
As a result, a large distance can be set between the 
start and end points of contour extraction, fewer 
feature points are required, and the corresponding 
point seek process can be done quicker. 

(4) Since new feature points are selected based 
on the shape of a newly extracted contour line every 
time it is extracted, a region of interest, the shape 
of which changes, can be extracted. 

Second Embodiment 

An image processing apparatus according to the 
second embodiment of the present invention will be 
described below. In this embodiment, the same 
reference numerals denote substantially the same parts 
as those in the first embodiment, and a detailed 
description thereof will be omitted. 

Fig. 15 is a block diagram showing an example of 
the detailed arrangement of a contour extractor 10 of 
the second embodiment. In Fig. 15, a contour 
extraction characteristic select section 200 that gives 



different contour extraction characteristics to the 
edge trace section 100 is added to the arrangement of 
the contour extractor 10 of the first embodiment shown 
in Fig. 1. 

5 In the first embodiment, the constraint condition 

of contour trace is relaxed as much as possible to 
assure a maximum degree of freedom in trace path. 
Therefore, when the edge strength of the contour line 
is relatively higher than those of neighboring edges 

Lli 

;;f 10 and noise, contour trace of the first embodiment is 

!:f very effective. However, if the strengths of edges and 

noise that neighbor the contour line are higher than 
t3 the edge strength of the contour line, a trace error is 

1= highly likely to occur due to a broader field of view. 

-s .a. 
: ; = 

fj 15 In the second embodiment, the screen masks shown 

; . 

in Fig. 12, and those shown in Fig. 16 are provided, 
and one of those masks is selectively used. The screen 
mask shown in Fig. 12 allows trace in five directions, 
but the number of traceable directions of the screen 

20 mask shown in Fig. 16 is limited to three. This 

amounts to applying a constraint condition "to always 
approach the target point" to contour trace. Therefore, 
according to the screen mask shown in Fig. 16, since 
the degree of freedom in contour trace path lowers 

25 compared to the process using the screen mask shown in 
Fig. 12, a neighboring edge other than a contour is 
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unlikely to be erroneously detected, resulting in high 
stability. 

Fig. 17 shows the contour traceable range when 
the screen masks shown in Fig. 16 are used. Range a 
5 shown in Fig. 17 indicates a traceable range when point 
C of interest is located at start point A, and range b 
a traceable range when point C of interest is located 
on the contour of range b. In this way, the traceable 
range reduces as point C of interest becomes closer to 

m 

iij 10 target point B, and target point B is finally reached 
fiJ with high reliability. 

t:L The contour extraction characteristic select 

2 

section 200 selects contour extraction characteristics 

iSI 

12 in accordance with the strength, contrast, variance, 

15 and the like of an edge in a partial region sandwiched 

L-l, 

between connected feature points in the edge image 
obtained by the contour extractor 10. Alternatively, 
edge trace processes based on different contour 
extraction characteristics, i.e., using different 

20 screen masks, may be parallelly executed, and a desired 
contour trace result may be selected on the basis of 
the smoothness, edge strength, contrast, and the like 
of the extracted contour line. 

As described above, according to the second 

25 embodiment, the following effects can be obtained in 
addition to those of the first embodiment. 
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(5) Since screen masks having stricter field 
limitations are used, a contour line with a low edge 
strength, a contour line of a noisy image, and the like 
can be stably traced without being influenced by a 
strong edge and noise other than the contour line. 

(6) Since the contour extraction characteristics 
can be adaptively changed by selectively using the 
screen mask shown in Fig. 16 for a strong edge other 
than the contour or the screen mask shown in Fig. 12 
for a strong edge of the contour line, the application 
range of contour extraction can be broadened. 

Third Embodiment 

In the first and second embodiments mentioned 
above, neighboring pixels of the point of interest 
undergo binary masking. In the third embodiment, 
neighboring pixels undergo not only binary masking but 
also multi-valued weighting to change contour 
extraction characteristics more smoothly. 

Figs. 18A to 18D show examples of screen masks of 
direction 5 using multi-valued weighting coefficients. 
Of course, weighting coefficients shown in Figs. 18A to 
18D are merely examples, and may be changed more finely. 
The screen masks shown in Figs. 18A to 18C are 
equivalent to those shown in Figs. 12 and 16. On the 
other hand, the screen mask shown in Fig. 18B has an 
intermediate constraint condition between those shown 
in Figs. 12 and 16, and the screen mask shown in 



Fig. 18D has a constraint condition stricter than that 
shown in Fig. 16. 

Therefore, when the edge strengths of neighboring 
pixels of the point of interest are not clearly 
different from each other, i.e., when an edge is 
discontinuous or the contrast is low, contour trace 
that prioritizes a direction toward the target point 
can be continued by selectively using the weighted 
screen mask shown n Fig. 18A or 18B. On the other hand, 
at a position having opposite characteristics, the 
weighted screen mask shown in Fig. 18C or 18D may be 
selectively used. 

As described above, according to the third 
embodiment, the following effects can be obtained in 
addition to the effects of the first and second 
embodiments . 

(7) Even at a position where an edge is unsharp, 
contour trace can be continued in a direction toward 
the target point. 

(8) Since a plurality of screen masks having 
different weighting coefficients are prepared, and can 
be freely selected in correspondence with the image 
state around the contour, the present invention can be 
applied to every image contours. 

Fourth Embodiment 

In the first to third embodiments described above, 
one-way contour trace from the start point to the end 
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point has been explained. However, when one-way 
contour trace is made, a wrong direction may be 
selected at branch paths of an edge. For this reason, 
in the fourth embodiment, contour trace in the opposite 
5 direction is made by replacing the start and end points. 
The two-way trace effects will be explained below using 
Figs. 19 and 20. 

Figs. 19 and 20 show a true contour line, and a 
background edge which overlaps that contour line. 

10 Assume that the background edge has a higher edge 

strength than the true contour line. In Fig. 19, start 
point A is present on the lower side of this figure, 
end point B is located on the upper side, and a contour 
is traced from the lower side toward the upper side of 

15 the figure. When a contour line is traced in a 

direction shown in Fig. 19 (to be referred to as a 
"forward direction" hereinafter) , a traced line goes in 
the direction of the background edge having a higher 
edge strength, is separated from the background edge 

20 under the influences of the screen masks during trace, 
and then goes toward end point B, as shown in Fig. 19. 
That is. Fig. 19 shows a typical failure example of 
edge trace. 

On the other hand, since the combination of start 
25 point A and end point B in Fig. 20 is reversed to that 
shown in Fig. 19, contour trace goes from the upper 
side to the lower side of the figure, i.e., in a 
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direction opposite to that in Fig. 19. Therefore, the 
branch point of edges in Fig. 19 changes to a merge 
point of edges in Fig. 20. Of course, since the 
screen masks do not allow to trace a direction to 
separate away from target point B, trace can extract a 
correct contour without turning back in a direction of 
the background edge at the merge point, irrespective of 
the presence of a stronger background edge. 

Fig. 21 is a flow chart showing the process of 
the fourth embodiment . 

Contour trace shown in Fig. 10 is executed in 
step S300, and its reliability is evaluated in step 
S301. This evaluation is achieved by solely using the 
smoothness of a contour line, the average value of edge 
strengths on a contour line, the length (path length) 
of a contour line, or the like, or systematically by 
weighting and summing up these parameters. The start 
and end points are replaced in step S302, contour trace 
shown in Fig. 10 is executed again in step S303, and 
its reliability is evaluated in step S304. In step 
S305, the evaluation results of the contour trace 
results in the two directions are compared to output a 
contour trace result with higher reliability. 

As described above, according to the fourth 
embodiment, the following effects can be obtained in 
addition to those of the first to third embodiments. 
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(9) Since contour trace processes are done in 
two directions, and a contour trace result with higher 
reliability is selected, very stable contour trace, 
which is hardly influenced by an "edge other than a 

5 contour" which crosses the contour line, can be 
realized. 

(10) In the fourth embodiment, the effectiveness 
of two-way contour trace has been explained in 
consideration of an edge branch point. Of course, 

10 since the "edge branch point" is an "edge merge point" 
when viewed from the opposite direction, very stable 
contour trace, which is hardly influenced by an "edge 
other than a contour" can be realized in combination 
with mask processes which realize constraint conditions 

15 such as "to go toward the target point", "not to 

regress to the previous moving direction", and the like. 
However, mask processes are not indispensable in 
two-way contour trace of the fourth embodiment. In 
some cases, forward and backward contour trace paths 

20 near two end points are different from each other due 
to, e.g., the absence of a sharp edge near the two end 
points of a contour to be extracted, and contour trace 
results in two directions consequently indicate quite 
different paths. Even in such case, since one of the 

25 contour trace results in the two directions extracts a 
true contour line, two-way contour trace is greatly 
advantageous compared to one-way contour trace. 
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Fifth Embodiment 

The first embodiment uses Freeman chain codes as 
shape information of a contour line as a feature point 
select method on the contour line. The fifth 
embodiment uses image information on or near the 
contour line in addition to the shape information of 
the contour line. As an example of image information, 
the strengths of edges of pixels which form the contour 
line are referred to. That is, feature point 
candidates on the contour line are selected on the 
basis of the shape information of the contour line, and 
are prioritized on the basis of their edge strengths. 
Higher priority is assigned to a feature point having 
higher edge strength, since such point allows 
corresponding point seek with higher precision in the 
next frame- A maximum number of feature points, 
determined by the processing performance of a system 
that extracts a region of interest, are selected using 
the prioritizing results. 

Also, the fifth embodiment is effective upon 
determining a pixel of a high-resolution original image 
corresponding to a feature point extracted from a 
resolution-reduced image, that has been explained in 
the first embodiment. That is, when a pixel of an 
original image with highest reliability is selected 
from a "coarse pixel region consisting of four pixels 
of the original image" selected as a feature point in 
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the low-resolution image, the edge strengths of the 
four pixels of the original image can be compared with 
each other, and a pixel with highest edge strength is 
automatically selected . 

According to the feature point select method of 
the fifth embodiment, the following effects are 
obtained. 

(11) Guidelines upon selecting a predetermined 
number of feature points from many feature point 
candidates can be given. 

(12) A feature point with higher reliability can 
be selected from many feature point candidates. 

(13) A corresponding feature point of a 
high-resolution image can be obtained from that of a 
low-resolution image . 

Sixth Embodiment 

The first embodiment has explained the method of 
selecting feature points on a contour line using 
Freeman chain codes as shape information of the contour 
line, and the fifth embodiment has exemplified a case 
wherein image information on or near the contour line 
is used in addition to the shape information of the 
contour line. In the sixth embodiment, a method of 
selecting feature points from two-way trace results 
using the fourth embodiment will be explained. 

The principle of the fourth embodiment will be 
explained below with reference to Figs. 19 and 20. In 
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forward trace shown in Fig. 19, a background edge 
having a higher edge strength begins to be traced at 
the branch point of the background edge that crosses a 
contour line. However^ a line traced up to the branch 
point is correct. On the other hand, in reverse trace 
shown in Fig. 20, since the branch point is a merge 
point of a true contour line and background edge, it 
does not adversely influence contour trace. Upon 
comparing the forward and reverse trace results, the 
trace results between start point A in Fig. 19 and the 
branch point match, and the trace results between the 
branch point and end point B in Fig. 19 do not match. 
In the sixth embodiment, end points of a period where 
two-way trace results match are selected as feature 
points . 

That is, if the branch point shown in Fig. 19 is 
selected as a feature point, a branch point from which 
the traced line deviates can be removed, and a feature 
point with higher reliability can be selected. When 
the sixth embodiment is combined with the first or 
fifth embodiment, the reliability of feature points can 
be further improved. 

According to the sixth embodiment, the following 
unique effect can be obtained. 

(14) Feature points which cannot be selected 
based on only the shape or edge strengths of the 
contour line can be selected without any omissions. 
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Especially, this embodiment is effective when a strong 
edge is present in the background or region of interest 
Seventh Embodiment 

The corresponding point seeker 30 of the first 
embodiment independently performs block matching using 
blocks each consisting of a feature point and its 
neighboring pixels. On the other hand, an LSI that 
detects motion vectors has been developed, and precise 
motion vectors in an image can be detected in real time 
Using such motion vector detection LSI together, a 
search range in the next frame can be limited by 
feature points selected on the current frame, and the 
following unique effect can be obtained. 

(15) Since a corresponding point seek range in 
the next frame can be roughly limited based on the 
distribution of motion vectors near feature points, the 
processing efficiency can be improved by omitting an 
inefficient corresponding point seek process, and 
correspondence errors of feature points can be 
eliminated. 

As many apparently widely different embodiments 
of the present invention can be made without departing 
from the spirit and scope thereof, it is to be 
understood that the invention is not limited to the 
specific embodiments thereof except as defined in the 
appended claims. 
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